/**
 * request插件地址：https://ext.dcloud.net.cn/plugin?id=822
 */
import store from '@/store'
import request from './request'
import Config from '@/core/config'

// 后端api地址
const apiUrl = Config.get('apiUrl')

// 可以new多个request来支持多个域名请求
const $http = new request({
  // 接口请求地址
  baseUrl: apiUrl,
  // 服务器本地上传文件地址
  fileUrl: apiUrl,
  // 服务器上传图片默认url
  defaultUploadUrl: 'upload/image',
  // 设置请求头（如果使用报错跨域问题，可能是content-type请求类型和后台那边设置的不一致）
  header: {
    'content-type': 'application/json;charset=utf-8'
  },
  // 请求超时时间, 单位ms（默认15000）
  timeout: 15000,
  // 默认配置（可不写）
  config: {
    // 是否自动提示错误
    isPrompt: true,
    // 是否显示加载动画
    load: true,
    // 是否使用数据工厂
    isFactory: true
  }
})

// 当前接口请求数
let requestNum = 0
// 请求开始拦截器
$http.requestStart = options => {
	// console.log('fasd6677', options)
  if (options.load) {
    if (requestNum <= 0) {
      // 打开加载动画
      uni.showLoading({
        title: '加载中',
        mask: true
      })
    }
    requestNum += 1
  }
  // 图片上传大小限制
  // if (options.method == "FILE" && options.maxSize) {
  //   // 文件最大字节: options.maxSize 可以在调用方法的时候加入参数
  //   const maxSize = options.maxSize
  //   for (let item of options.files) {
  //     if (item.size > maxSize) {
  //       setTimeout(() => {
  //         uni.showToast({
  //           title: "图片过大，请重新上传",
  //           icon: "none"
  //         })
  //       }, 10)
  //       return false
  //     }
  //   }
  // }
	let token = uni.getStorageSync('token')
	options.header['Content-Type'] = 'application/json;charset=utf-8'	
	options.header['x-syscode'] = '02'	
	// options.header['isToken'] =  token? true : false
	if (token) {
		options.header['token'] = token // 让每个请求携带自定义token 请根据实际情况自行修改
		if (uni.getStorageSync('userInfoRole')) {
			let val = {}
			if (JSON.parse(uni.getStorageSync('userInfo')).userType == '02') {
				val.mrId = JSON.parse(uni.getStorageSync('userInfoRole')).id
				if (JSON.parse(uni.getStorageSync('userInfoRole')).agencyId) {
					val.mrId = JSON.parse(uni.getStorageSync('userInfoRole')).id
					val.agencyId = JSON.parse(uni.getStorageSync('userInfoRole')).agencyId
				}
				// val.agencyId = undefined
			} else if (JSON.parse(uni.getStorageSync('userInfo')).userType == '01') {
				// val.mrId = undefined
				val.agencyId = JSON.parse(uni.getStorageSync('userInfoRole')).id
				
			}
			//  else {
			// 	val.mrId = JSON.parse(uni.getStorageSync('userInfoRole')).id
			// 	val.agencyId = JSON.parse(uni.getStorageSync('userInfoRole')).agencyId
			// }
			options.data = { ...val, ...options.data }
		}
		
	}
  // 请求前加入当前终端
  // options.header['platform'] = store.getters.platform
  // // 请求前加入Token
  // options.header['Access-Token'] = store.getters.token
  // return false 表示请求拦截，不会继续请求
	
	

	
	
	
  return options
}

// 请求结束
$http.requestEnd = options => {
  // 判断当前接口是否需要加载动画
  if (options.load) {
    requestNum = requestNum - 1
    if (requestNum <= 0) {
			setTimeout(() => {
				// uni.hideLoading()
			}, 500)
    }
  }
}

// 当前是否显示modal
let loginModal = false

// 所有接口数据处理（可在接口里设置不调用此方法）
// 此方法需要开发者根据各自的接口返回类型修改，以下只是模板
$http.dataFactory = async res => {
	 let httpData = res.response.data
  if ((!res.response.data || res.response.data.code != 200) && res.response.data.code != 401) {
    // 返回错误的结果(catch接受数据)
    // return Promise.reject({
    //   statusCode: res.response.statusCode,
    //   errMsg: 'http状态码错误'
    // })
		setTimeout(() => {
		  uni.showToast({
		    title: httpData.msg,
		    icon: "none",
		    duration: 2500
		  }, 10)
		})
		// 返回错误的结果(catch接受数据)
		return Promise.reject({
		  statusCode: 0,
		  errMsg: httpData.msg,
		  result: httpData
		})
  }

 


  // 判断数据是否请求成功
  // result.status [ 200正常 500有错误 401未登录 403没有权限访问 ]
  if (httpData.code == 200) {
    // 返回正确的结果(then接受数据)
		if (httpData.status == 1 || httpData.status == 2) {
			setTimeout(() => {
			  uni.showToast({
			    title: httpData.msg,
			    icon: "none",
			    duration: 2500
			  }, 10)
			})
			// 返回错误的结果(catch接受数据)
			return Promise.reject({
			  statusCode: 0,
			  errMsg: httpData.msg,
			  result: httpData
			})
			
		} else {
			setTimeout(() => {
				uni.hideLoading()
			}, 500)
			return Promise.resolve(httpData)
		}
  }

  // 判断是否需要登录
  if (httpData.code == 401) {
    // 401也有可能是后端登录态到期, 所以要清空本地的登录状态
    // store.dispatch('Logout')
		setTimeout(() => {
		  uni.showToast({
		    title: '登录过期,请重新登录',
		    icon: "none",
		    duration: 2500,
		  }, 10)
		})
		uni.navigateTo({
			url: "/pages/login/index"
		})
		uni.removeStorageSync("token");
    // 防止重复弹窗
    // if (!loginModal) {
    //   loginModal = true
    //   // 弹窗告诉用户去登录
    //   uni.showModal({
    //     title: '温馨提示',
    //     content: '此时此刻需要您登录喔~',
    //     // showCancel: false,
    //     confirmText: "去登录",
    //     cancelText: "再逛会",
    //     success: res => {
    //       if (res.confirm) {
    //         uni.navigateTo({
    //           url: "/pages/login/index"
    //         })
    //       }
    //       if (res.cancel && getCurrentPages().length > 1) {
    //         uni.navigateBack()
    //       }
    //       loginModal = false
    //     }
    //   })
    // }
    // 返回错误的结果(catch接受数据)
    return Promise.reject({
      statusCode: 0,
      errMsg: httpData.message,
      result: httpData
    })
  }
}

// 错误回调
$http.requestError = e => {
  if (e.statusCode === 0) {
    throw e
  } else {
    setTimeout(() => showRequestError(e), 10)
  }
}

// 显示请求错误信息
const showRequestError = (e) => {
  let errMsg = `网络请求出错：${e.errMsg}`
  // #ifdef MP-WEIXIN
  if (e.errMsg === 'request:fail url not in domain list') {
    errMsg = '当前API域名未添加到微信小程序授权名单 ' + e.errMsg
  }
  // #endif
  if (e.errMsg === 'request:fail') {
    errMsg = '网络请求错误：请检查api地址能否访问正常'
  }
  uni.showToast({
    title: errMsg,
    icon: "none",
    duration: 3500
  })
}

export default $http
